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module prep2_2 (DATAO, DATA1, DATA2, LDPRE, SEL, RST, CLK.LDCOMP); 
output [7:0] DATAO; 
input [7:0] DATA1, DATA2; 
input LDPRE, SEL, RST, CLK, LDCOMP; 
wire [7:0] DATAOJnternal; 

prep2_1 instl (CLK, RST, SEL, LDCOMP, LDPRE, DATA1, DATA2, DATAOJnternal); 
prep2_1 inst2 (CLK, RST, SEL, LDCOMP, LDPRE, DATAOJnternal, DATA2, DATAO); 

endmodule 



703 



module prep2_1 (CLK, RST, SEL, LDCOMP, LDPRE, DATA1, DATA2, DATAO); 
input CLK, RST, SEL, LDCOMP, LDPRE; 
input [7:0] DATA1.DATA2; 
output [7:0] DATAO; 



reg [7:0 
reg [7:0; 



DATAO; 

highreg_output, lowreg_output; // internal registers 



wire compare_output = (DATA == lowreg_output); // comparator 
wire [7:0] mux.output = SEL ? DATA1 : highreg.output; // mux 

// registers 

always @ (posedge CLK or posedge RST) 
begin 

if (RST) begin 

highreg_output = 0; 

lowreg_output = 0; 
end else begin 

if (LDPRE) 

highreg_output = DATA2; 
if (LDCOMP) 
lowreg_output = DATA2; 

end 

end 

// counter 

always @ (posedge CLK or posedge RST) 
begin 

if (RST) 

DATAO = 0 
else if (compare_output) // load 

DATAO = mux_output; 

else 

DATAO = DATAO + 1; 

end 

endmodule 
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